document.addEventListener('DOMContentLoaded', () => {
	/* 公共修改地址栏URL函数 */
	const changeURLArg = (url, arg, arg_val) => {
		let pattern = arg + '=([^&]*)';
		let replaceText = arg + '=' + arg_val;
		if (url.match(pattern)) {
			let tmp = '/(' + arg + '=)([^&]*)/gi';
			return url.replace(eval(tmp), replaceText);
		} else {
			if (url.match('[?]')) {
				return url + '&' + replaceText;
			} else {
				return url + '?' + replaceText;
			}
		}
		return url + '\n' + arg + '\n' + arg_val;
	};

	/* 初始化昼夜模式 */
	{
		if (localStorage.getItem('data-night')) {
			$('.joe_action_item.mode .icon-1').addClass('active');
			$('.joe_action_item.mode .icon-2').removeClass('active');
		} else {
			$('html').removeAttr('data-night');
			$('.joe_action_item.mode .icon-1').removeClass('active');
			$('.joe_action_item.mode .icon-2').addClass('active');
		}
		$('.joe_action_item.mode').on('click', () => {
			if (localStorage.getItem('data-night')) {
				$('.joe_action_item.mode .icon-1').removeClass('active');
				$('.joe_action_item.mode .icon-2').addClass('active');
				$('html').removeAttr('data-night');
				localStorage.removeItem('data-night');
			} else {
				$('.joe_action_item.mode .icon-1').addClass('active');
				$('.joe_action_item.mode .icon-2').removeClass('active');
				$('html').attr('data-night', 'night');
				localStorage.setItem('data-night', 'night');
			}
		});
	}

	/* 动态背景 */
	{
		if (!Joe.IS_MOBILE && Joe.DYNAMIC_BACKGROUND !== 'off' && Joe.DYNAMIC_BACKGROUND && !Joe.WALLPAPER_BACKGROUND_PC) {
			$.getScript(`/usr/themes/Joe/assets/backdrop/${Joe.DYNAMIC_BACKGROUND}`);
		}
	}

	/* 搜索框弹窗 */
	{
		$('.joe_header__above-search .input').on('click', e => {
			e.stopPropagation();
			$('.joe_header__above-search .result').addClass('active');
		});
		$(document).on('click', function () {
			$('.joe_header__above-search .result').removeClass('active');
		});
		$(document).on('scroll', function () {
			$('.joe_header__above-search .result').removeClass('active');
		});
	}

	/* 激活全局下拉框功能 */
	{
		$('.joe_dropdown').each(function (index, item) {
			const menu = $(this).find('.joe_dropdown__menu');
			const trigger = $(item).attr('trigger') || 'click';
			const placement = $(item).attr('placement') || $(this).height() || 0;
			menu.css('top', placement);
			if (trigger === 'hover') {
				$(this).hover(
					() => $(this).addClass('active'),
					() => $(this).removeClass('active')
				);
			} else {
				$(this).on('click', function (e) {
					$(this).toggleClass('active');
					$(document).one('click', () => $(this).removeClass('active'));
					e.stopPropagation();
				});
				menu.on('click', e => e.stopPropagation());
			}
		});
	}

	/* 激活全局返回顶部功能 */
	{
		const handleScroll = () => ((document.documentElement.scrollTop || document.body.scrollTop) > 300 ? $('.joe_action_item.scroll').addClass('active') : $('.joe_action_item.scroll').removeClass('active'));
		handleScroll();
		$(window).on('scroll', () => handleScroll());
		$('.joe_action_item.scroll').on('click', () => window.scrollTo({ top: 0, behavior: 'smooth' }));
	}

	/* 激活侧边栏人生倒计时功能 */
	{
		if ($('.joe_aside__item.timelife').length !== 0) {
			let timelife = [
				{ title: '今日已经过去', endTitle: '小时', num: 0, percent: '0%' },
				{ title: '这周已经过去', endTitle: '天', num: 0, percent: '0%' },
				{ title: '本月已经过去', endTitle: '天', num: 0, percent: '0%' },
				{ title: '今年已经过去', endTitle: '个月', num: 0, percent: '0%' }
			];
			{
				let nowDate = +new Date();
				let todayStartDate = new Date(new Date().toLocaleDateString()).getTime();
				let todayPassHours = (nowDate - todayStartDate) / 1000 / 60 / 60;
				let todayPassHoursPercent = (todayPassHours / 24) * 100;
				timelife[0].num = parseInt(todayPassHours);
				timelife[0].percent = parseInt(todayPassHoursPercent) + '%';
			}
			{
				let weeks = { 0: 7, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6 };
				let weekDay = weeks[new Date().getDay()];
				let weekDayPassPercent = (weekDay / 7) * 100;
				timelife[1].num = parseInt(weekDay);
				timelife[1].percent = parseInt(weekDayPassPercent) + '%';
			}
			{
				let year = new Date().getFullYear();
				let date = new Date().getDate();
				let month = new Date().getMonth() + 1;
				let monthAll = new Date(year, month, 0).getDate();
				let monthPassPercent = (date / monthAll) * 100;
				timelife[2].num = date;
				timelife[2].percent = parseInt(monthPassPercent) + '%';
			}
			{
				let month = new Date().getMonth() + 1;
				let yearPass = (month / 12) * 100;
				timelife[3].num = month;
				timelife[3].percent = parseInt(yearPass) + '%';
			}
			let htmlStr = '';
			timelife.forEach((item, index) => {
				htmlStr += `
						<div class="item">
							<div class="title">
								${item.title}
								<span class="text">${item.num}</span>
								${item.endTitle}
							</div>
							<div class="progress">
								<div class="progress-bar">
									<div class="progress-bar-inner progress-bar-inner-${index}" style="width: ${item.percent}"></div>
								</div>
								<div class="progress-percentage">${item.percent}</div>
							</div>
						</div>`;
			});
			$('.joe_aside__item.timelife .joe_aside__item-contain').html(htmlStr);
		}
	}

	/* 激活侧边栏天气功能 */
	{
		if ($('.joe_aside__item.weather').length !== 0) {
			const key = $('.joe_aside__item.weather').attr('data-key');
			const style = $('.joe_aside__item.weather').attr('data-style');
			const aqiColor = { 1: 'FFFFFF', 2: '4A4A4A', 3: 'FFFFFF' };
			window.WIDGET = { CONFIG: { layout: 2, width: '220', height: '270', background: style, dataColor: aqiColor[style], language: 'zh', key: key } };
			$.getScript('http://apip.weatherdt.com/standard/static/js/weather-standard.js?v=2.0');
		}
	}

	/* 激活侧边栏排行榜功能 */
	{
		if ($('.joe_aside__item.ranking').length !== 0) {
			$.ajax({
				url: Joe.BASE_API,
				type: 'POST',
				dataType: 'json',
				data: { routeType: 'aside_ranking' },
				success(res) {
					$('.joe_aside__item.ranking .joe_aside__item-title .text').html(res.title);
					let htmlStr = '';
					if (res.code === 1) {
						res.data.forEach((item, index) => {
							htmlStr += `
									<li class="item">
										<span class="sort">${index + 1}</span>
										<a class="link" href="${item.url}" title="${item.title}" target="_blank" rel="noopener noreferrer nofollow">${item.title}</a>
									</li>
								`;
						});
					} else {
						htmlStr += `<li class="error">数据抓取异常！</li>`;
					}
					$('.joe_aside__item.ranking .joe_aside__item-contain').html(htmlStr);
				}
			});
		}
	}

	/* 3d云标签 */
	{
		if ($('.joe_aside__item.tags').length !== 0) {
			const entries = [];
			const colors = ['#F8D800', '#0396FF', '#EA5455', '#7367F0', '#32CCBC', '#F6416C', '#28C76F', '#9F44D3', '#F55555', '#736EFE', '#E96D71', '#DE4313', '#D939CD', '#4C83FF', '#F072B6', '#C346C2', '#5961F9', '#FD6585', '#465EFB', '#FFC600', '#FA742B', '#5151E5', '#BB4E75', '#FF52E5', '#49C628', '#00EAFF', '#F067B4', '#F067B4', '#ff9a9e', '#00f2fe', '#4facfe', '#f093fb', '#6fa3ef', '#bc99c4', '#46c47c', '#f9bb3c', '#e8583d', '#f68e5f'];
			const random = (min, max) => {
				min = Math.ceil(min);
				max = Math.floor(max);
				return Math.floor(Math.random() * (max - min + 1)) + min;
			};
			$('.joe_aside__item-contain .list li').each((i, item) => {
				entries.push({
					label: $(item).attr('data-label'),
					url: $(item).attr('data-url'),
					target: '_blank',
					fontColor: colors[random(0, colors.length - 1)],
					fontSize: 15
				});
			});
			$('.joe_aside__item-contain .tag').svg3DTagCloud({
				entries,
				width: 220,
				height: 220,
				radius: '65%',
				radiusMin: 75,
				bgDraw: false,
				fov: 800,
				speed: 0.5,
				fontWeight: 500
			});
		}
	}

	/* 设置侧边栏最后一个元素的高度 */
	{
		$('.joe_aside__item:last-child').css('top', $('.joe_header').height() + 15);
	}

	/* 激活Live2d人物 */
	{
		if (Joe.LIVE2D !== 'off' && Joe.LIVE2D) {
			$.getScript('https://cdn.jsdelivr.net/npm/live2d-widget@3.1.4/lib/L2Dwidget.min.js', () => {
				L2Dwidget.init({
					model: { jsonPath: Joe.LIVE2D, scale: 1 },
					mobile: { show: false },
					display: { position: 'right', width: 160, height: 200, hOffset: 70, vOffset: 0 }
				});
			});
		}
	}

	/* 计算页面滚动多少 */
	{
		const calcProgress = () => {
			let scrollTop = $(window).scrollTop();
			let documentHeight = $(document).height();
			let windowHeight = $(window).height();
			let progress = parseInt((scrollTop / (documentHeight - windowHeight)) * 100);
			if (progress <= 0) progress = 0;
			if (progress >= 100) progress = 100;
			$('.joe_header__below-progress').css('width', progress + '%');
		};
		calcProgress();
		$(window).on('scroll', () => calcProgress());
	}

	/* 评论框点击切换画图模式和文本模式 */
	{
		$('.joe_comment__respond-type .item').on('click', function () {
			$(this).addClass('active').siblings().removeClass('active');
			if ($(this).attr('data-type') === 'draw') {
				$('.joe_comment__respond-form .body .draw').show().siblings().hide();
				$('#joe_comment_draw').prop('width', $('.joe_comment__respond-form .body').width());
				/* 设置表单格式为画图模式 */
				$('.joe_comment__respond-form').attr('data-type', 'draw');
			} else {
				$('.joe_comment__respond-form .body .text').show().siblings().hide();
				/* 设置表单格式为文字模式 */
				$('.joe_comment__respond-form').attr('data-type', 'text');
			}
		});
	}

	/* 激活画图功能 */
	{
		if ($('#joe_comment_draw').length !== 0) {
			/* 激活画板 */
			window.sketchpad = new Sketchpad({ element: '#joe_comment_draw', height: 300, penSize: 5, color: '303133' });
			/* 撤销上一步 */
			$('.joe_comment__respond-form .body .draw .icon-undo').on('click', () => window.sketchpad.undo());
			/* 动画预览 */
			$('.joe_comment__respond-form .body .draw .icon-animate').on('click', () => window.sketchpad.animate(10));
			/* 更改画板的线宽 */
			$('.joe_comment__respond-form .body .draw .line li').on('click', function () {
				window.sketchpad.penSize = $(this).attr('data-line');
				$(this).addClass('active').siblings().removeClass('active');
			});
			/* 更改画板的颜色 */
			$('.joe_comment__respond-form .body .draw .color li').on('click', function () {
				window.sketchpad.color = $(this).attr('data-color');
				$(this).addClass('active').siblings().removeClass('active');
			});
		}
	}

	/* 重写评论功能 */
	{
		const respond = $('.joe_comment__respond');
		/* 重写回复功能 */
		$('.joe_comment__reply').on('click', function () {
			/* 父级ID */
			const coid = $(this).attr('data-coid');
			/* 当前的项 */
			const item = $('#' + $(this).attr('data-id'));
			/* 添加自定义属性表示父级ID */
			respond.find('.joe_comment__respond-form').attr('data-coid', coid);
			item.append(respond);
			$(".joe_comment__respond-type .item[data-type='text']").click();
			$('.joe_comment__cancle').show();
			window.scrollTo({
				top: item.offset().top - $('.joe_header').height() - 15,
				behavior: 'smooth'
			});
		});
		/* 重写取消回复功能 */
		$('.joe_comment__cancle').on('click', function () {
			/* 移除自定义属性父级ID */
			respond.find('.joe_comment__respond-form').removeAttr('data-coid');
			$('.joe_comment__cancle').hide();
			$('.joe_comment__title').after(respond);
			$(".joe_comment__respond-type .item[data-type='text']").click();
			window.scrollTo({
				top: $('.joe_comment').offset().top - $('.joe_header').height() - 15,
				behavior: 'smooth'
			});
		});
	}

	/* 激活评论提交 */
	{
		let isSubmit = false;
		$('.joe_comment__respond-form').on('submit', function (e) {
			e.preventDefault();
			const url = $('.joe_comment__respond-form').attr('action') + '?time=' + +new Date();
			const type = $('.joe_comment__respond-form').attr('data-type');
			const parent = $('.joe_comment__respond-form').attr('data-coid');
			const author = $(".joe_comment__respond-form .head input[name='author']").val();
			const mail = $(".joe_comment__respond-form .head input[name='mail']").val();
			let text = $(".joe_comment__respond-form .body textarea[name='text']").val();
			if (author.trim() === '') return Qmsg.info('请输入昵称！');
			if (!/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(mail)) return Qmsg.info('请输入正确的邮箱！');
			if (type === 'text' && text.trim() === '') return Qmsg.info('请输入评论内容！');
			if (type === 'draw') {
				const txt = $('#joe_comment_draw')[0].toDataURL('image/webp', 0.1);
				text = '{!{' + txt + '}!} ';
			}
			if (isSubmit) return;
			isSubmit = true;
			$('.joe_comment__respond-form .foot .submit button').html('发送中...');
			$.ajax({
				url,
				type: 'POST',
				data: { author, mail, text, parent },
				dataType: 'text',
				success(res) {
					let arr = [],
						str = '';
					arr = $(res).contents();
					Array.from(arr).forEach(_ => {
						if (_.parentNode.className === 'container') str = _;
					});
					if (!/Joe/.test(res)) {
						Qmsg.warning(str.textContent.trim() || '');
						isSubmit = false;
						$('.joe_comment__respond-form .foot .submit button').html('发表评论');
					} else {
						window.location.href = changeURLArg(location.href, 'scroll', 'joe_comment');
					}
				}
			});
		});
	}

	/* 切换标签显示不同的标题 */
	{
		if (Joe.DOCUMENT_TITLE) {
			const TITLE = document.title;
			document.addEventListener('visibilitychange', () => {
				if (document.visibilityState === 'hidden') {
					document.title = Joe.DOCUMENT_TITLE;
				} else {
					document.title = TITLE;
				}
			});
		}
	}

	/* 小屏幕伸缩侧边栏 */
	{
		$('.joe_header__above-slideicon').on('click', function () {
			/* 关闭搜索框 */
			$('.joe_header__searchout').removeClass('active');
			/* 处理开启关闭状态 */
			if ($('.joe_header__slideout').hasClass('active')) {
				$('body').css('overflow', '');
				$('.joe_header__mask').removeClass('active slideout');
				$('.joe_header__slideout').removeClass('active');
			} else {
				$('body').css('overflow', 'hidden');
				$('.joe_header__mask').addClass('active slideout');
				$('.joe_header__slideout').addClass('active');
			}
		});
	}

	/* 小屏幕搜索框 */
	{
		$('.joe_header__above-searchicon').on('click', function () {
			/* 关闭侧边栏 */
			$('.joe_header__slideout').removeClass('active');
			/* 处理开启关闭状态 */
			if ($('.joe_header__searchout').hasClass('active')) {
				$('body').css('overflow', '');
				$('.joe_header__mask').removeClass('active slideout');
				$('.joe_header__searchout').removeClass('active');
			} else {
				$('body').css('overflow', 'hidden');
				$('.joe_header__mask').addClass('active');
				$('.joe_header__searchout').addClass('active');
			}
		});
	}

	/* 点击遮罩层关闭 */
	{
		$('.joe_header__mask').on('click', function () {
			$('body').css('overflow', '');
			$('.joe_header__mask').removeClass('active slideout');
			$('.joe_header__searchout').removeClass('active');
			$('.joe_header__slideout').removeClass('active');
		});
	}

	/* 移动端侧边栏菜单手风琴 */
	{
		$('.joe_header__slideout-menu .current').parents('.panel-body').show().siblings('.panel').addClass('in');
		$('.joe_header__slideout-menu .panel').on('click', function () {
			const panelBox = $(this).parent().parent();
			/* 清除全部内容 */
			panelBox.find('.panel').not($(this)).removeClass('in');
			panelBox.find('.panel-body').not($(this).siblings('.panel-body')).stop().hide('fast');
			/* 激活当前的内容 */
			$(this).toggleClass('in').siblings('.panel-body').stop().toggle('fast');
		});
	}

	/* 初始化网站运行时间 */
	{
		const getRunTime = () => {
			const birthDay = new Date(Joe.BIRTHDAY);
			const today = +new Date();
			const timePast = today - birthDay.getTime();
			let day = timePast / (1000 * 24 * 60 * 60);
			let dayPast = Math.floor(day);
			let hour = (day - dayPast) * 24;
			let hourPast = Math.floor(hour);
			let minute = (hour - hourPast) * 60;
			let minutePast = Math.floor(minute);
			let second = (minute - minutePast) * 60;
			let secondPast = Math.floor(second);
			day = String(dayPast).padStart(2, 0);
			hour = String(hourPast).padStart(2, 0);
			minute = String(minutePast).padStart(2, 0);
			second = String(secondPast).padStart(2, 0);
			$('.joe_run__day').html(day);
			$('.joe_run__hour').html(hour);
			$('.joe_run__minute').html(minute);
			$('.joe_run__second').html(second);
		};
		if (Joe.BIRTHDAY && /(\d{4})\/(\d{1,2})\/(\d{1,2}) (\d{1,2})\:(\d{1,2})\:(\d{1,2})/.test(Joe.BIRTHDAY)) {
			getRunTime();
			setInterval(getRunTime, 1000);
		}
	}

	/* 初始化表情功能 */
	{
		if ($('.joe_owo__contain').length > 0 && $('.joe_owo__target').length > 0) {
			$.ajax({
				url: '/usr/themes/Joe/assets/json/joe.owo.json',
				dataType: 'json',
				success(res) {
					let barStr = '';
					let scrollStr = '';
					for (let key in res) {
						barStr += `<div class="item" data-index="${res[key].index}">${key}</div>`;
						scrollStr += `
                            <ul class="scroll" data-index="${res[key].index}">
                                ${res[key].container.map(_ => `<li class="item" data-text="${_.data}">${_.icon}</li>`).join('')} 
                            </ul>
                        `;
					}
					$('.joe_owo__contain').html(`
                        <div class="seat">OωO</div>
                        <div class="box">
                            ${scrollStr}
                            <div class="bar">${barStr}</div>
                        </div>
                    `);
					$(document).on('click', function () {
						$('.joe_owo__contain .box').stop().slideUp('fast');
					});
					$('.joe_owo__contain .seat').on('click', function (e) {
						e.stopPropagation();
						$(this).siblings('.box').stop().slideToggle('fast');
					});
					$('.joe_owo__contain .box .bar .item').on('click', function (e) {
						e.stopPropagation();
						$(this).addClass('active').siblings().removeClass('active');
						const scrollIndx = '.joe_owo__contain .box .scroll[data-index="' + $(this).attr('data-index') + '"]';
						$(scrollIndx).show().siblings('.scroll').hide();
					});
					/* 点击表情，向文本框插入内容 */
					$('.joe_owo__contain .scroll .item').on('click', function () {
						const text = $(this).attr('data-text');
						$('.joe_owo__target').insertContent(text);
					});
					/* 默认激活第一个 */
					$('.joe_owo__contain .box .bar .item').first().click();
				}
			});
		}
	}

	/* 座右铭 */
	{
		let motto = Joe.MOTTO;
		if (!motto) motto = '有钱终成眷属，没钱亲眼目睹';
		if (motto.includes('http')) {
			$.ajax({
				url: motto,
				dataType: 'text',
				success: res => $('.joe_motto').html(res)
			});
		} else {
			$('.joe_motto').html(motto);
		}
	}
});
